# **Bug Report**

# **CSCE 714: Advanced Hardware Design Functional Verification**

**Multicore MESI Based Cache Design HAS** 

Team 17: Hunter Britton, Christopher Muniz, Jaewoo Lee

| Team Number                       | # 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bug Number                        | # 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bug Location                      | Main_func_lv1_dl.sv line: 176                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bug Type                          | Functional Bug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SV Test Run to uncover the Bug    | Read_hit_dcache                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Checker/Assertion Failed          | assert_release_after_gnt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Checker Description               | If the bus_rd or bus_rdx is asserted, lv_2 has to be asserted too                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bug Description/ Debug<br>Process | Send a read request into the dcache on each processor. Since the read request hits multiple processors and the code does not return the value down to zero the rd_register is never freed.  Read_hit_dcache ensures that there is a free block and that the read needs to be in the second cache, by reading to the dcache.  Starting at the beginning of the readmiss and reading down to the free block if statement, the bus_rd_reg was not deasserted after the data was put into the bus for lv1/lv2. |
| Original Code                     | Line 176: bus_rd_reg <= 1'b0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Code after Fix                    | bus_rd_reg <= 1'b1;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 2.1 Free block available in the set

- Bus access is been requested (bus 1v1 1v2 req proc made high)
- Wait till Access is granted (bus\_lv1\_lv2\_gnt\_proc to be made high by arbiter)
- Once access granted, bus\_rd and lv2\_rd is raised
- Address of the requested data block is put in addr\_bus\_lv1\_lv2

As lv2\_rd gets <u>deasserted</u>, <u>bus\_rd</u> goes to high impedance and throws an error, leading to a state of unsure where the lv2\_rd should be.



Lv2\_rd gets <u>deasserted</u>, and <u>bus\_rd</u> gets deasserted



| Team Number                       | # 17                                                                                                                                                                                                                                                                                                 |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bug Number                        | # 2                                                                                                                                                                                                                                                                                                  |
| Bug Location                      | Main_func_lv1_dl.sv @ 221                                                                                                                                                                                                                                                                            |
| Bug Type                          | Functional Bug                                                                                                                                                                                                                                                                                       |
| SV Test Run to uncover the Bug    | read_two_procs_force_write.sv                                                                                                                                                                                                                                                                        |
| Checker/Assertion Failed          | assert_wr_completion                                                                                                                                                                                                                                                                                 |
| Checker Description               | Checks to see if wr_done is asserted within 100 cycles of cpu_wr being asserted to showcase that the write is done.                                                                                                                                                                                  |
| Bug Description/ Debug<br>Process | When forcing two processors to read the same address to push the state into shared, and then force a write on the same address, the test was written to force an invalidate on the shared state, the state should move to INVALID and invalidate the write leading to a cpu_wr_done being scheduled. |
| Original Code                     | invalidate_reg <= 1'bz;                                                                                                                                                                                                                                                                              |
| Code after Fix                    | invalidate_reg <= 1'b1;                                                                                                                                                                                                                                                                              |



Figure 2-1

If the Cache data is in Shared condition then the following is carried out

- Once bus\_lv1\_lv2\_gnt\_proc is high;
- Address of the block to be invalidated is regenerated from its TAG (stored in cache\_proc\_contr) and index\_proc value and is put in addr bus lv1 lv2 bus.
- Signal "invalidate" is made high asking other level 1 caches to make their copy, if present, to be Invalid.
- When all such copies are invalidated, all\_invalidation\_done is made high.
- The cache\_var is then updated with data\_bus\_lv1\_lv2 value.
- cache\_proc\_contr [index\_proc, blk\_access\_proc][MESI] value is updated with updated mesi\_proc value.
- cpu wr done is raised.
- bus lv1 lv2 req proc is deasserted



| Team Number                       | # 17                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bug Number                        | #3                                                                                                                                                                                                                                                                                                                                                          |
| Bug Location                      | Main_func_lv1_dl.sv @ 259                                                                                                                                                                                                                                                                                                                                   |
| Bug Type                          | Functional Bug                                                                                                                                                                                                                                                                                                                                              |
| SV Test Run to uncover the Bug    | write_miss.sv                                                                                                                                                                                                                                                                                                                                               |
| Checker/Assertion Failed          | Assertion assert_bus_rd_rdx_with_lv2_rd Failed: bus_rd/bus_rdx asserted without a lv2_rd                                                                                                                                                                                                                                                                    |
| Checker Description               | Checks to see if bus_rd or bus_rdx is asserted without lv2_rd                                                                                                                                                                                                                                                                                               |
| Bug Description/ Debug<br>Process | Writing randomly to an address in the d_cache to verify that signals are properly deasserted, and asserted When accessing Iv2 cache, at the end of the write all signals need to be deasserted.  The assertion failed, and by looking at the waveform bus_rdx_reg is not deasserted properly, leading to the assertion hitting, rather it is asserted high. |
| Original Code                     | bus_rdx_reg <= 1'b1;                                                                                                                                                                                                                                                                                                                                        |
| Code after Fix                    | bus_rdx_reg <= 1'b0;                                                                                                                                                                                                                                                                                                                                        |

Bus\_rdx gets asserted when bus\_rd is asserted



Bus rdx gets asserted low when bus rd is asserted low



#### 3.2 Processor Write miss

Similar to Read Miss, Write Miss also has two possibilities which are free block/line available and free block/line not available.

### (1) Free block available

The following operations are carried out at Proc side of the requesting cache.

If a free line is available. (Processor Write miss in L1 Cache with Shared / Exclusive

A University Page 11

# CSCE 689-700: Advanced Hardware Design Verification

## / Modified state)

- bus\_lv1\_lv2\_req\_proc is raised.
- Wait till bus\_lv1\_lv2\_gnt\_proc to be made high by arbiter.
- Once access granted, bus\_rdx and lv2\_rd is raised
- Address of the requested data block is put in addr\_bus\_lv1\_lv2.
- Wait till level 2 cache provides the data. Communicated by making data\_in\_bus\_lv1\_lv2 high. ATTENTION: data will only be provided by level 2 cache in this case because other level 1 caches will first make their copies Invalid.
- Once data\_in\_bus\_lv1\_lv2 becomes high, cache\_var [index\_proc, blk\_access\_proc] is updated with value from data\_bus\_lv1\_lv2. cache\_proc\_contr [index\_proc, blk\_access\_proc] [MESI\_range] is updated with updated\_mesi\_proc. cache\_proc\_contr [index\_proc, blk\_access\_proc] [Tag\_range] is updated with tag\_proc.

After this operation, the block will automatically become block hit and previously mentioned Processor Write Hit operation is carried out.

```
Test PASS

Test PASS
```